package cn.joker.config;

import cn.dev33.satoken.interceptor.SaInterceptor;
import cn.dev33.satoken.stp.StpUtil;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class SaTokenConfigure implements WebMvcConfigurer {
    // 注册拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 注册 Sa-Token 拦截器，校验规则为 StpUtil.checkLogin() 登录校验。
        registry.addInterceptor(new SaInterceptor(handle -> StpUtil.checkLogin()))
                .addPathPatterns("/**")
                .excludePathPatterns(
                        "/auth/login",             // 登录接口放行
                        "/v3/api-docs/**",         // OpenAPI JSON 放行
//                        "/druid/*",              // 连接池放行
                        "/swagger-ui/**",          // Swagger UI 放行
                        "/doc.html",               // Knife4j UI 放行
                        "/webjars/**",             // 静态资源放行
                        "/favicon.ico"
                );
    }
}
